[INFO] cloning repository https://github.com/Idan3011/vigilo
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Idan3011/vigilo" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdan3011%2Fvigilo", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdan3011%2Fvigilo'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7675adfb119de03d0287196547a431f1fb366292
[INFO] testing Idan3011/vigilo against master#f9988fefd3add01f414f52b414308e7872622fee for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdan3011%2Fvigilo" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-2-tc1/source/.cargo/config.toml
[INFO] started tweaking git repo https://github.com/Idan3011/vigilo
[INFO] finished tweaking git repo https://github.com/Idan3011/vigilo
[INFO] tweaked toml for git repo https://github.com/Idan3011/vigilo written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Idan3011/vigilo on toolchain f9988fefd3add01f414f52b414308e7872622fee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Idan3011/vigilo already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded security-framework-sys v2.16.0
[INFO] [stderr]   Downloaded native-tls v0.2.16
[INFO] [stderr]   Downloaded security-framework v3.6.0
[INFO] [stderr]   Downloaded cookie_store v0.22.1
[INFO] [stderr]   Downloaded notify v7.0.0
[INFO] [stderr]   Downloaded notify-types v1.0.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] aec30fa28886409c0a6b55569181dd5fd9dea749f45814779834b5c98747f322
[INFO] running `Command { std: "docker" "start" "-a" "aec30fa28886409c0a6b55569181dd5fd9dea749f45814779834b5c98747f322", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "aec30fa28886409c0a6b55569181dd5fd9dea749f45814779834b5c98747f322", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "aec30fa28886409c0a6b55569181dd5fd9dea749f45814779834b5c98747f322", kill_on_drop: false }`
[INFO] [stdout] aec30fa28886409c0a6b55569181dd5fd9dea749f45814779834b5c98747f322
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 421c183a66b0caf1d280537b68653d394d77b9083b73c19e89383cc1e0e6b653
[INFO] running `Command { std: "docker" "start" "-a" "421c183a66b0caf1d280537b68653d394d77b9083b73c19e89383cc1e0e6b653", kill_on_drop: false }`
[INFO] [stderr]    Compiling quote v1.0.44
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling cc v1.2.55
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling zerocopy v0.8.39
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling futures-task v0.3.32
[INFO] [stderr]    Compiling zmij v1.0.19
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling native-tls v0.2.16
[INFO] [stderr]    Compiling deranged v0.5.6
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling cookie v0.18.1
[INFO] [stderr]    Compiling psl-types v2.0.11
[INFO] [stderr]    Compiling unicase v2.9.0
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling document-features v0.2.12
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling instant v0.1.13
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling regex-syntax v0.8.9
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling anyhow v1.0.101
[INFO] [stderr]    Compiling axum-core v0.5.6
[INFO] [stderr]    Compiling notify-types v1.0.1
[INFO] [stderr]    Compiling vigilo v1.0.3 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling sha1_smol v1.0.1
[INFO] [stderr]    Compiling fallible-iterator v0.3.0
[INFO] [stderr]    Compiling matchit v0.8.4
[INFO] [stderr]    Compiling fallible-streaming-iterator v0.1.9
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling include_dir_macros v0.7.4
[INFO] [stderr]    Compiling similar v2.7.0
[INFO] [stderr]    Compiling include_dir v0.7.4
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling inotify v0.10.2
[INFO] [stderr]    Compiling filetime v0.2.27
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling aead v0.5.2
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling libsqlite3-sys v0.28.0
[INFO] [stderr]    Compiling polyval v0.6.2
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling notify v7.0.0
[INFO] [stderr]    Compiling ghash v0.5.1
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling fs2 v0.4.3
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling aes-gcm v0.10.3
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling uuid v1.20.0
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling hashlink v0.9.1
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling publicsuffix v2.3.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling cookie_store v0.22.1
[INFO] [stderr]    Compiling rusqlite v0.31.0
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 25s
[INFO] running `Command { std: "docker" "inspect" "421c183a66b0caf1d280537b68653d394d77b9083b73c19e89383cc1e0e6b653", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "421c183a66b0caf1d280537b68653d394d77b9083b73c19e89383cc1e0e6b653", kill_on_drop: false }`
[INFO] [stdout] 421c183a66b0caf1d280537b68653d394d77b9083b73c19e89383cc1e0e6b653
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] dc1b2216fe19759c0331de62a6b180c127f3b64cc9bf65edafe6e46545966dad
[INFO] running `Command { std: "docker" "start" "-a" "dc1b2216fe19759c0331de62a6b180c127f3b64cc9bf65edafe6e46545966dad", kill_on_drop: false }`
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling rusqlite v0.31.0
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]    Compiling native-tls v0.2.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling vigilo v1.0.3 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 29.63s
[INFO] running `Command { std: "docker" "inspect" "dc1b2216fe19759c0331de62a6b180c127f3b64cc9bf65edafe6e46545966dad", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "dc1b2216fe19759c0331de62a6b180c127f3b64cc9bf65edafe6e46545966dad", kill_on_drop: false }`
[INFO] [stdout] dc1b2216fe19759c0331de62a6b180c127f3b64cc9bf65edafe6e46545966dad
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 6919089fdc432509a13cbcf8d2263cb073fed3fb034074c5e1de11b2bce1a507
[INFO] running `Command { std: "docker" "start" "-a" "6919089fdc432509a13cbcf8d2263cb073fed3fb034074c5e1de11b2bce1a507", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.46s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/vigilo-da301d5d6be58abd)
[INFO] [stdout] 
[INFO] [stdout] running 198 tests
[INFO] [stdout] test crypto::tests::decrypt_invalid_base64_returns_none ... ok
[INFO] [stdout] test crypto::tests::decrypt_short_payload_returns_none ... ok
[INFO] [stdout] test crypto::tests::decrypt_without_prefix_returns_none ... ok
[INFO] [stdout] test crypto::tests::generate_key_b64_is_unique ... ok
[INFO] [stdout] test crypto::tests::generate_key_b64_produces_valid_32_byte_key ... ok
[INFO] [stdout] test cli::tests::parse_date_passthrough ... ok
[INFO] [stdout] test crypto::tests::is_encrypted_detects_prefix ... ok
[INFO] [stdout] test cli::tests::parse_date_months ... ok
[INFO] [stdout] test cli::tests::parse_date_weeks ... ok
[INFO] [stdout] test crypto::tests::encrypt_decrypt_empty_string ... ok
[INFO] [stdout] test crypto::tests::non_encrypted_string_not_detected ... ok
[INFO] [stdout] test crypto::tests::round_trip ... ok
[INFO] [stdout] test cursor::tests::aggregate_cached_tokens_empty ... ok
[INFO] [stdout] test cursor::tests::aggregate_cached_tokens_sums_correctly ... ok
[INFO] [stdout] test crypto::tests::load_key_from_file_returns_none_for_invalid ... ok
[INFO] [stdout] test cursor::tests::auth_cookie_format ... ok
[INFO] [stdout] test cursor::tests::cached_token_event_from_api ... ok
[INFO] [stdout] test crypto::tests::load_key_from_file_returns_none_for_missing ... ok
[INFO] [stdout] test cursor::tests::cached_token_event_from_api_invalid_timestamp ... ok
[INFO] [stdout] test crypto::tests::load_or_create_key_generates_when_missing ... ok
[INFO] [stdout] test cursor::tests::cached_token_event_round_trips_through_json ... ok
[INFO] [stdout] test crypto::tests::generate_and_save_key_creates_file ... ok
[INFO] [stdout] test cursor::tests::auth_cookie_encodes_colons ... ok
[INFO] [stdout] test cursor::tests::fmt_cost_cents_small ... ok
[INFO] [stdout] test cursor::tests::fmt_cost_cents_medium ... ok
[INFO] [stdout] test cursor::tests::is_system_user_allows_normal ... ok
[INFO] [stdout] test cursor::tests::needs_local_copy_mnt_paths ... ok
[INFO] [stdout] test cursor::tests::percent_encode_encodes_special_chars ... ok
[INFO] [stdout] test cursor::tests::percent_encode_leaves_unreserved ... ok
[INFO] [stdout] test cursor::tests::token_totals_from_event ... ok
[INFO] [stdout] test cursor::tests::token_totals_from_event_missing_fields ... ok
[INFO] [stdout] test cursor::tests::cached_token_event_from_api_missing_timestamp ... ok
[INFO] [stdout] test cursor::tests::token_totals_merge ... ok
[INFO] [stdout] test git::tests::dirty_in_false_for_non_repo ... ok
[INFO] [stdout] test cursor::tests::fmt_cost_cents_large ... ok
[INFO] [stdout] test cursor::tests::is_system_user_filters_known ... ok
[INFO] [stdout] test cli::tests::parse_date_days ... ok
[INFO] [stdout] test hook::tests::build_claude_outcome_error_extracts_message ... ok
[INFO] [stdout] test cli::tests::parse_date_today ... ok
[INFO] [stdout] test git::tests::root_in_returns_none_for_non_repo ... ok
[INFO] [stdout] test hook::tests::claude_session_id_from_session_id_field ... ok
[INFO] [stdout] test hook::tests::build_claude_outcome_error_via_is_error ... ok
[INFO] [stdout] test hook::tests::claude_session_id_from_transcript_path ... ok
[INFO] [stdout] test crypto::tests::wrong_key_returns_none ... ok
[INFO] [stdout] test hook::tests::build_claude_outcome_ok_stores_null_by_default ... ok
[INFO] [stdout] test hook::tests::cursor_cwd_fallback_to_dot ... ok
[INFO] [stdout] test hook::tests::claude_session_id_prefers_session_id_over_transcript_path ... ok
[INFO] [stdout] test hook::tests::cursor_cwd_from_cwd_field ... ok
[INFO] [stdout] test hook::tests::cursor_cwd_from_workspace_roots ... ok
[INFO] [stdout] test hook::tests::detect_client_claude_code_without_conversation_id ... ok
[INFO] [stdout] test hook::tests::detect_client_cursor_has_conversation_id ... ok
[INFO] [stdout] test hook::tests::normalize_cursor_model_default_becomes_auto ... ok
[INFO] [stdout] test hook::tests::normalize_cursor_model_passes_through ... ok
[INFO] [stdout] test hook::tests::is_process_alive_for_current_process ... ok
[INFO] [stdout] test hook::tests::build_claude_outcome_error_via_success_false ... ok
[INFO] [stdout] test hook::tests::build_claude_outcome_ok ... ok
[INFO] [stdout] test hook::tests::is_process_alive_bogus_pid ... ok
[INFO] [stdout] test hook::tests::parse_claude_tool_strips_content_from_write_file ... ok
[INFO] [stdout] test hook::tests::parse_cursor_event_read_file ... ok
[INFO] [stdout] test hook::tests::parse_cursor_event_unknown_passthrough ... ok
[INFO] [stdout] test hook::tests::parse_cursor_file_edit_multiple_edits ... ok
[INFO] [stdout] test hook::tests::parse_cursor_file_edit_no_edits ... ok
[INFO] [stdout] test hook::tests::parse_claude_tool_extracts_name_and_args ... ok
[INFO] [stdout] test hook::tests::parse_cursor_file_edit_empty_edits_array ... ok
[INFO] [stdout] test hook::tests::parse_cursor_file_edit_with_diff ... ok
[INFO] [stdout] test hook::tests::parse_cursor_post_tool_use_falls_back_to_arguments ... ok
[INFO] [stdout] test hook::tests::parse_cursor_post_tool_use_canonicalizes_shell ... ok
[INFO] [stdout] test hook::tests::parse_cursor_post_tool_use_strips_content ... ok
[INFO] [stdout] test hook::tests::parse_claude_tool_strips_content_from_write ... ok
[INFO] [stdout] test hook::tests::parse_cursor_post_tool_use_strips_mcp_prefix ... ok
[INFO] [stdout] test hook::tests::parse_cursor_post_tool_use_write_becomes_edit ... ok
[INFO] [stdout] test hook_helpers::tests::check_transcript_format_accepts_snapshot_then_message ... ok
[INFO] [stdout] test hook_helpers::tests::check_transcript_format_accepts_valid ... ok
[INFO] [stdout] test hook_helpers::tests::check_transcript_format_rejects_foreign ... ok
[INFO] [stdout] test hook::tests::read_mcp_session_id_from_tempfile ... ok
[INFO] [stdout] test hook_helpers::tests::check_transcript_format_rejects_empty ... ok
[INFO] [stdout] test hook_helpers::tests::compute_edit_diff_returns_diff_for_edit ... ok
[INFO] [stdout] test hook_helpers::tests::compute_edit_diff_returns_none_for_non_edit ... ok
[INFO] [stdout] test hook_helpers::tests::compute_edit_diff_works_for_multi_edit ... ok
[INFO] [stdout] test hook_helpers::tests::compute_tool_duration_uses_now_when_no_result ... ok
[INFO] [stdout] test hook_helpers::tests::compute_unified_diff_handles_empty_strings ... ok
[INFO] [stdout] test hook::tests::read_mcp_session_id_stale_pid ... ok
[INFO] [stdout] test hook_helpers::tests::compute_tool_duration_from_transcript ... ok
[INFO] [stdout] test hook_helpers::tests::compute_unified_diff_returns_diff_for_changes ... ok
[INFO] [stdout] test hook_helpers::tests::extract_error_message_fallback ... ok
[INFO] [stdout] test hook::tests::parse_cursor_event_mcp_execution ... ok
[INFO] [stdout] test hook_helpers::tests::compute_unified_diff_returns_none_for_identical ... ok
[INFO] [stdout] test hook_helpers::tests::extract_error_message_from_content_text ... ok
[INFO] [stdout] test hook_helpers::tests::has_tool_result_id_no_match ... ok
[INFO] [stdout] test hook_helpers::tests::has_tool_use_id_finds_match ... ok
[INFO] [stdout] test hook_helpers::tests::has_tool_use_id_no_match ... ok
[INFO] [stdout] test hook_helpers::tests::extract_error_message_from_error_field ... ok
[INFO] [stdout] test hook_helpers::tests::find_last_tool_use_id_from_transcript ... ok
[INFO] [stdout] test hook_helpers::tests::has_tool_result_id_finds_match ... ok
[INFO] [stdout] test hook_helpers::tests::parse_timestamp_micros_missing ... ok
[INFO] [stdout] test hook_helpers::tests::parse_timestamp_micros_invalid ... ok
[INFO] [stdout] test hook_helpers::tests::parse_timestamp_micros_valid ... ok
[INFO] [stdout] test hook_helpers::tests::read_transcript_meta_returns_default_for_missing_file ... ok
[INFO] [stdout] test hook::tests::parse_cursor_event_shell_execution ... ok
[INFO] [stdout] test hook_helpers::tests::resolve_git_dir_from_path_for_grep ... ok
[INFO] [stdout] test hook_helpers::tests::read_transcript_meta_computes_duration_without_tool_use_id ... ok
[INFO] [stdout] test hook_helpers::tests::resolve_git_dir_from_file_path_for_read ... ok
[INFO] [stdout] test hook_helpers::tests::resolve_git_dir_generic_tool_checks_file_path_first ... ok
[INFO] [stdout] test hook_helpers::tests::has_tool_use_id_non_array_returns_false ... ok
[INFO] [stdout] test hook_helpers::tests::stable_uuid_is_deterministic ... ok
[INFO] [stdout] test hook_helpers::tests::stable_uuid_differs_for_different_input ... ok
[INFO] [stdout] test hook_helpers::tests::resolve_git_dir_falls_back_to_cwd ... ok
[INFO] [stdout] test hook_helpers::tests::scan_transcript_usage_extracts_model_and_tokens ... ok
[INFO] [stdout] test hook_helpers::tests::log_error_appends_to_file ... ok
[INFO] [stdout] test ledger::tests::append_event_returns_error_for_directory_path ... ok
[INFO] [stdout] test ledger::tests::append_event_writes_valid_json_line ... ok
[INFO] [stdout] test models::tests::is_vigilo_mcp_tool_matches_all_14_tools ... ok
[INFO] [stdout] test models::tests::is_vigilo_mcp_tool_rejects_non_mcp_tools ... ok
[INFO] [stdout] test models::tests::mcp_event_default_has_zero_values ... ok
[INFO] [stdout] test models::tests::load_config_returns_empty_for_missing_file ... ok
[INFO] [stdout] test ledger::tests::prune_returns_zero_when_nothing_to_remove ... ok
[INFO] [stdout] test ledger::tests::prune_removes_old_rotated_files ... ok
[INFO] [stdout] test models::tests::mcp_event_flatten_backward_compatible ... ok
[INFO] [stdout] test models::tests::mcp_event_serializes_and_deserializes ... ok
[INFO] [stdout] test hook_helpers::tests::scan_transcript_usage_skips_non_assistant ... ok
[INFO] [stdout] test models::tests::mcp_session_path_contains_vigilo ... ok
[INFO] [stdout] test models::tests::risk_classify_strips_mcp_prefix ... ok
[INFO] [stdout] test models::tests::risk_classify_unknown_tool ... ok
[INFO] [stdout] test models::tests::shorten_home_replaces_prefix ... ok
[INFO] [stdout] test models::tests::shorten_home_leaves_unrelated_paths ... ok
[INFO] [stdout] test server::execute::tests::arg_str_missing_key_returns_err ... ok
[INFO] [stdout] test server::execute::tests::arg_str_returns_value ... ok
[INFO] [stdout] test git::tests::commit_in_returns_none_without_commits ... ok
[INFO] [stdout] test server::execute::tests::execute_get_file_info_returns_metadata ... ok
[INFO] [stdout] test server::execute::tests::execute_delete_file_missing_returns_err ... ok
[INFO] [stdout] test server::execute::tests::execute_read_file_missing_path_arg_returns_err ... ok
[INFO] [stdout] test server::execute::tests::execute_get_file_info_on_directory ... ok
[INFO] [stdout] test server::execute::tests::execute_create_directory_makes_nested_dirs ... ok
[INFO] [stdout] test server::execute::tests::execute_move_file_renames_file ... ok
[INFO] [stdout] test server::execute::tests::execute_read_file_returns_contents ... ok
[INFO] [stdout] test server::execute::tests::execute_run_command_nonzero_exit_returns_err ... ok
[INFO] [stdout] test git::tests::name_in_extracts_from_https_remote ... ok
[INFO] [stdout] test server::execute::tests::execute_run_command_respects_cwd ... ok
[INFO] [stdout] test server::execute::tests::execute_delete_file_removes_file ... ok
[INFO] [stdout] test server::execute::tests::execute_search_files_no_matches ... ok
[INFO] [stdout] test server::execute::tests::execute_list_directory_returns_sorted_names ... ok
[INFO] [stdout] test server::execute::tests::execute_unknown_tool_returns_err ... ok
[INFO] [stdout] test server::execute::tests::execute_search_files_finds_matches ... ok
[INFO] [stdout] test server::execute::tests::risk_classify_read_tools ... ok
[INFO] [stdout] test server::execute::tests::risk_classify_exec_tool ... ok
[INFO] [stdout] test server::execute::tests::risk_classify_write_tools ... ok
[INFO] [stdout] test server::execute::tests::risk_classify_unknown_returns_unknown ... ok
[INFO] [stdout] test server::execute::tests::tool_names_match_vigilo_tools ... ok
[INFO] [stdout] test server::execute::tests::execute_run_command_returns_stdout ... ok
[INFO] [stdout] test server::tests::dispatch_initialize_returns_protocol_version ... ok
[INFO] [stdout] test git::tests::name_in_extracts_from_ssh_remote ... ok
[INFO] [stdout] test server::tests::dispatch_ping_returns_empty_result ... ok
[INFO] [stdout] test server::tests::dispatch_missing_method_returns_none ... ok
[INFO] [stdout] test server::execute::tests::execute_search_files_skips_binary_files ... ok
[INFO] [stdout] test server::tests::dispatch_unknown_method_returns_none ... ok
[INFO] [stdout] test server::tests::dispatch_tools_list_returns_14_tools ... ok
[INFO] [stdout] test server::execute::tests::execute_write_file_creates_and_writes ... ok
[INFO] [stdout] test setup::tests::ensure_hook_entry_is_idempotent ... ok
[INFO] [stdout] test setup::tests::ensure_hook_entry_preserves_existing ... ok
[INFO] [stdout] test setup::tests::home_returns_home_dir ... ok
[INFO] [stdout] test setup::tests::is_vigilo_hook_present_false_for_null ... ok
[INFO] [stdout] test server::tests::schema_tool_names_match_tool_names ... ok
[INFO] [stdout] test setup::tests::is_vigilo_hook_present_false_for_other_hook ... ok
[INFO] [stdout] test setup::tests::binary_path_returns_something ... ok
[INFO] [stdout] test setup::tests::is_vigilo_hook_present_true_when_configured ... ok
[INFO] [stdout] test setup::tests::read_json_or_empty_parses_valid_json ... ok
[INFO] [stdout] test server::tests::dispatch_tools_call_error_returns_jsonrpc_error ... ok
[INFO] [stdout] test setup::tests::read_json_or_empty_returns_empty_for_invalid_json ... ok
[INFO] [stdout] test setup::tests::read_json_or_empty_returns_empty_for_missing_file ... ok
[INFO] [stdout] test setup::tests::write_json_creates_parent_dirs ... ok
[INFO] [stdout] test view::data::tests::load_sessions_date_filter ... ok
[INFO] [stdout] test view::data::tests::load_sessions_last_limits_sessions ... ok
[INFO] [stdout] test view::data::tests::all_ledger_files_finds_rotated_files ... ok
[INFO] [stdout] test view::fmt::tests::diff_summary_ignores_file_headers ... ok
[INFO] [stdout] test view::fmt::tests::fmt_duration_micros ... ok
[INFO] [stdout] test view::fmt::tests::fmt_duration_millis ... ok
[INFO] [stdout] test view::fmt::tests::fmt_duration_seconds ... ok
[INFO] [stdout] test view::fmt::tests::short_path_falls_back_to_filename ... ok
[INFO] [stdout] test view::fmt::tests::short_path_strips_project_root ... ok
[INFO] [stdout] test view::fmt::tests::strip_ansi_preserves_plain_text ... ok
[INFO] [stdout] test view::fmt::tests::strip_ansi_removes_escape_sequences ... ok
[INFO] [stdout] test view::fmt::tests::trunc_preserves_short_strings ... ok
[INFO] [stdout] test view::fmt::tests::trunc_truncates_long_strings ... ok
[INFO] [stdout] test setup::tests::is_vigilo_hook_present_false_when_empty ... ok
[INFO] [stdout] test view::fmt::tests::diff_summary_counts_adds_and_removes ... ok
[INFO] [stdout] test setup::tests::ensure_hook_entry_adds_new_entry ... ok
[INFO] [stdout] test view::data::tests::load_tail_events_returns_all_when_fewer_than_n ... ok
[INFO] [stdout] test view::data::tests::load_tail_events_returns_last_n ... ok
[INFO] [stdout] test setup::tests::write_config_all_scenarios ... ok
[INFO] [stdout] test server::tests::dispatch_tools_call_read_file_round_trip ... ok
[INFO] [stdout] test git::tests::name_in_returns_none_without_remote ... ok
[INFO] [stdout] test git::tests::root_in_returns_repo_root ... ok
[INFO] [stdout] test git::tests::dirty_in_false_on_clean_repo ... ok
[INFO] [stdout] test git::tests::commit_in_returns_short_hash ... ok
[INFO] [stdout] test git::tests::name_in_handles_trailing_slash ... ok
[INFO] [stdout] test git::tests::dirty_in_true_with_uncommitted_changes ... ok
[INFO] [stdout] test git::tests::branch_in_returns_current_branch ... ok
[INFO] [stdout] test ledger::tests::append_event_triggers_rotation_over_10mb ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 198 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.94s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/ledger_smoke.rs (/opt/rustwide/target/debug/deps/ledger_smoke-6f1894dbbf2d4573)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test ledger_error_outcome_round_trips ... ok
[INFO] [stdout] test ledger_multiple_sessions ... ok
[INFO] [stdout] test ledger_round_trip ... ok
[INFO] [stdout] test ledger_large_file_contains_valid_events ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.25s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "6919089fdc432509a13cbcf8d2263cb073fed3fb034074c5e1de11b2bce1a507", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6919089fdc432509a13cbcf8d2263cb073fed3fb034074c5e1de11b2bce1a507", kill_on_drop: false }`
[INFO] [stdout] 6919089fdc432509a13cbcf8d2263cb073fed3fb034074c5e1de11b2bce1a507
